Cody Cziesler and Nick Desaulniers Computer Organization Project 1 5/4/10

## OpCodes:

|       | OpCode<br>[15] | OpCode<br>[14] | OpCode<br>[13] | OpCode<br>[12] | Reg<br>Dst | Bran<br>ch | MemR<br>ead | MemTo<br>Reg | MemW<br>rite | ALUS<br>rc | RegWr<br>ite | Ju<br>mp | ALUOp<br>[1] | ALUOp<br>[2] | ALUOp<br>[3] | ALUOp<br>[4] |
|-------|----------------|----------------|----------------|----------------|------------|------------|-------------|--------------|--------------|------------|--------------|----------|--------------|--------------|--------------|--------------|
| tfr   | 0              | 0              | 0              | 0              | 0          | 0          | 0           | ٥            | 0 -          | 0          | 1            | 0        | 0            | 0            | 0            | 1            |
| add   | 0              | 0              | 0              | 1              | 1          | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 0            | 0            | 0            | 1            |
| sub   | 0              | 0              | 1              | 0              | 1          | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 0            | 0            | 1            | 0            |
| and   | 0              | 0              | 1              | 1              | 1          | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 0            | 0            | 1            | 1            |
| or    | 0              | 1              | 0              | 0              | 1          | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 0            | 1            | 0            | o            |
| not   | 0              | 1              | 0              | 1              | 1          | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 0            | 1            | 0            | 1            |
| mul   | 0              | 1              | 1              | 0              | 1          | 0          | 0           | ٥            | 0            | 0          | 1            | 0        | 0            | 1            | 1            | 0            |
| div   | 0              | 1              | 1              | 1              | 1          | 0          | 0           | 0            | 0            | o          | 1            | 0        | O            | 1            | 1            | 1            |
| j     | 1              | 0              | 0              | 0              | х          | x          | 0           | x            | 0            | x          | 0            | 1        | х            | x            | х            | х            |
| sil   | 1              | 0              | 0              | 1              | 1          | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 1            | 0            | 0            | 0            |
| sir   | 1              | 0              | 1              | 0              | 1.         | 0          | 0           | 0            | 0            | 0          | 1            | 0        | 1            | 0            | 0            | 1            |
| beq   | 1              | 0              | 1              | 1              | х          | 1          | 0           | x            | 0            | 0          | 0            | 0        | 0            | 0            | 1            | o            |
| bne   | 1              | 1              | 0              | 0              | х          | 1          | 0           | x            | 0            | 0          | 0            | 0        | 0            | 0            | 1            | 0            |
| load  | 1              | 1              | 0              | 1              | 0          | O          | 1           | 1            | 0            | 1          | 1            | 0        | 0            | 0            | 0            | 1            |
| store | 1              | 1              | 1              | 0              | х          | 0          | 0           | X            | 1            | 1          | 0            | 0        | 0            | 0            | 0            | 1            |
| nop   | 1              | 1              | 1              | 1              | Х          | 0          | 0           | 0            | 0            | 0          | 0            | 0        | х            | х            | х            | х            |

## **Control Logic:**

RegDst = C + A'B + A'D

Branch = ABC'D' + AB'CD

MemRead = ABC'D MemToReg = ABC'D MemWrite = ABCD'

ALUSrc = ABC'D + ABCD'RegWrite = A' + C'D + B'CD'

Jump = AB'C'D'

ALUOp[1] = AB'C' + AB'D'

ALUOp[2] = A'BALUOp[3] = A'C

ALUOp[4] = A'D + BD + ACD' + A'B'D

## **OpCode Types:**

There are three types of encoding styles. Each one will tell the data path how to read the data.

## Math Type

| Opcode [15-12] | Source 1 [11-9] | Source 2 [8-6] | Destination [5-3] | Not Used [2-0] |
|----------------|-----------------|----------------|-------------------|----------------|
|                | <u> </u>        |                | l L J             |                |

This type is used for adding together two registers and placing the result in the destination. Some commonly used commands are add, sub, and, or, etc.